package com.ruoyi.system.mapper;

import java.util.List;
import com.ruoyi.system.domain.UserInfo;
import org.apache.ibatis.annotations.Select;

/**
 * 用户信息管理Mapper接口
 * 
 * @author ruoyi
 * @date 2024-09-28
 */
public interface UserInfoMapper 
{
    /**
     * 查询用户信息管理
     * 
     * @param userId 用户信息管理主键
     * @return 用户信息管理
     */
    UserInfo selectUserInfoByUserId(Long userId);

    /**
     * 查询用户信息管理
     *
     * @param account 用户账号
     * @return 用户信息管理
     */
    UserInfo selectUserInfoByAccount(String account);

    /**
     * 查询用户信息管理列表
     * 
     * @param userInfo 用户信息管理
     * @return 用户信息管理集合
     */
    List<UserInfo> selectUserInfoList(UserInfo userInfo);

    /**
     * 新增用户信息管理
     * 
     * @param userInfo 用户信息管理
     * @return 结果
     */
    int insertUserInfo(UserInfo userInfo);

    /**
     * 修改用户信息管理
     * 
     * @param userInfo 用户信息管理
     * @return 结果
     */
    int updateUserInfo(UserInfo userInfo);

    /**
     * 删除用户信息管理
     * 
     * @param userId 用户信息管理主键
     * @return 结果
     */
    int deleteUserInfoByUserId(Long userId);

    /**
     * 批量删除用户信息管理
     * 
     * @param userIds 需要删除的数据主键集合
     * @return 结果
     */
    int deleteUserInfoByUserIds(Long[] userIds);

    /**
     * 获取用户积分可折扣的金额
     * @param userId
     * @return
     */
    Long getUserCo2Reduce(Long userId);

    @Select("SELECT * FROM user_info WHERE openid = #{openid}")
    UserInfo selectUserInfoByOpenid(String openid);
}
